<template>
  <div>
    <!-- 一条文章单元格 -->
    <van-cell>
    <!-- 标题区域的插槽 -->
    <template #title>
      <div class="title-box">
        <!-- 标题 -->
        <span>{{ artObj.title }}</span>
        <!-- 单图 -->
<!--        <img v-if="artObj.cover.type === 1" class="thumb" :src="artObj.cover.images[0]" alt="">-->
        <van-image
          v-if="artObj.cover.type === 1"
          class="thumb"
          :src="artObj.cover.images[0]"
        >
          <template v-slot:error>图片走丢了</template>
        </van-image>
      </div>
      <!--  多图 -->
      <div class="thumb-box" v-if="artObj.cover.type > 1">
<!--          <img v-for="(imgUrl, index) in artObj.cover.images"
               :key="index"
               class="thumb"
               :src="imgUrl"
               alt=""
          >-->
        <van-image
            img v-for="(imgUrl, index) in artObj.cover.images"
            :key="index"
            class="thumb"
            :src="imgUrl"
            alt=""
          >
          <template v-slot:error>图片走丢了</template>
        </van-image>
      </div>
    </template>
    <!-- label 区域的插槽 -->
    <template #label>
      <div class="label-box">
        <div>
          <span>头条特约评论员</span>
          <span>{{ artObj.comm_count}}评论</span>
          <span>{{ artObj.pubdate }}</span>
        </div>
        <!-- 反馈按钮 -->
        <van-icon name="cross" @click.stop="show=true" v-if="isShow"/>
        <!-- 反馈面板 修改蒙层挂载点-->
        <van-action-sheet
          v-model="show"
          :actions="actions"
          @select="onSelect"
          @cancel="onCancel"
          @close="closeFn"
          get-container="body"
          :cancel-text="bottomText"
        />
      </div>
    </template>
  </van-cell>
  </div>
</template>

<script>
// 目标1：点击反馈“垃圾内容”数据的切换
// 1. 监听点击事件知道点击的是哪个
// 2. 切换action里面的数据

// 目标2：二级反馈数据出现，取消按钮文字做要改成“返回”
// :cancel-text='bottomText' 设置变量, onSelect 中，把变量值换成"返回"
// 目标3：点击底部按钮，要区分判断
//  1. 标签@cancel取消事件和事件方法
//  2. 在里面用bottomText的值,判断用户点击的是否为"返回"
//  把actions数据源换成firstActions
//  bottomText文字换成取消
//  强制让反馈面板 show = true 留下
import {firstActions, secondActions} from '@/api/report'

export default {
    props:{
      artObj: Object, // 文章对象
      isShow: {
          type: Boolean,
          default: true // 例如首页的地方不想再去动了，首页肯定没传isShow值进来
      }
    },
    data() {
        return {
            show: false, // 反馈面板显示/隐藏
            actions: firstActions, // 反馈面板选型数组
            bottomText: '取消'
        }
    },
    methods: {
      // 选择事件
      onSelect(action,item) {
        console.log(action) // {name: '反馈垃圾内容'}
        console.log(item) // 索引值
        // 默认情况下点击选项时不会自动收起
        // 可以通过 close-on-click-action 属性开启自动收起
        //this.show = false;
        if (action.name == '反馈垃圾内容')
        {
            this.actions = secondActions
            this.bottomText = '返回'
        }
        else if (action.name == '不感兴趣') {
            this.$emit('disLikeEV', this.artObj.art_id) // 子向父调用自定义事件传消息
            this.show = false // 无论成功或失败-直接让反馈面板隐藏
        } else { // 二级反馈选项
            this.$emit('reportEV', this.artObj.art_id, action.value)
            this.show = false // 关闭 - 下面的close会帮把反馈选项切回来
        }
      },
      // 底部按钮-点击事件
      onCancel() {
          if (this.bottomText === '返回') {
              this.show = true // 强制让他回来
              this.actions = firstActions
              this.bottomText = '取消'
          }
      },
      // 关闭面板-触发事件
      closeFn() {
          this.actions = firstActions
          this.bottomText = '取消'
      },
      // 文章单元格-点击事件
      cellClickFn() {

      }
    },
}
</script>

<style scoped lang="less">
/* 标题样式 */
.title-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* label描述样式 */
.label-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* 文章信息span */
.label-box span{
  margin: 0 3px;
  &:first-child{
    margin-left: 0;
  }
}

/* 图片的样式, 矩形黄金比例：0.618 */
.thumb {
  width: 113px;
  height: 70px;
  background-color: #f8f8f8;
  object-fit: cover;
}

/* 三图, 图片容器 */
.thumb-box {
  display: flex;
  justify-content: space-between;
}
</style>
